Kubernetes একটি অটোমেটেড কনটেইনার অর্কেস্ট্রেশন প্ল্যাটফর্ম যা ডিস্ট্রিবিউটেড অ্যাপ্লিকেশন এবং সার্ভিস পরিচালনা করতে ব্যবহৃত হয়। CouchDB একটি ডিস্ট্রিবিউটেড ডাটাবেস, যা ডেটা রেপ্লিকেশন এবং শার্ডিং সমর্থন করে, এবং এটি একটি কনটেইনারাইজড পরিবেশে Kubernetes এর সঙ্গে কার্যকরভাবে চলতে পারে। Kubernetes এর মাধ্যমে আপনি CouchDB ক্লাস্টার সেটআপ করতে পারেন, যা CouchDB সার্ভারকে আরও স্কেলেবল, উচ্চ উপলব্ধ এবং সহজে পরিচালনাযোগ্য করে তোলে।
এখানে আমরা CouchDB এবং Kubernetes এর মধ্যে ইন্টিগ্রেশন কিভাবে করতে হবে তা নিয়ে আলোচনা করব।
কubernetes এ CouchDB চালানোর জন্য প্রথমে CouchDB এর Docker image ব্যবহার করতে হবে। CouchDB এর অফিসিয়াল Docker ইমেজ ডকুমেন্টেশন অনুযায়ী, আপনি নিম্নলিখিত কমান্ডটি ব্যবহার করে CouchDB ইমেজ পেতে পারেন:
docker pull couchdb
এটি CouchDB এর সর্বশেষ সংস্করণের Docker ইমেজ ডাউনলোড করবে।
Kubernetes ক্লাস্টারে CouchDB চালানোর জন্য একটি Deployment তৈরি করতে হবে। এখানে একটি উদাহরণ দেওয়া হলো যা একটি CouchDB পড তৈরি করবে।
couchdb-deployment.yaml ফাইলটি তৈরি করুন:
apiVersion: apps/v1
kind: Deployment
metadata:
name: couchdb
spec:
replicas: 3
selector:
matchLabels:
app: couchdb
template:
metadata:
labels:
app: couchdb
spec:
containers:
- name: couchdb
image: couchdb:latest
ports:
- containerPort: 5984
volumeMounts:
- name: couchdb-storage
mountPath: /opt/couchdb/data
volumes:
- name: couchdb-storage
persistentVolumeClaim:
claimName: couchdb-pvc
---
apiVersion: v1
kind: Service
metadata:
name: couchdb
spec:
ports:
- port: 5984
selector:
app: couchdb
এই YAML ফাইলটি একটি CouchDB Deployment তৈরি করবে যা ৩টি পড তৈরি করবে এবং একটি Service তৈরি করবে যা CouchDB এর পডের সাথে যোগাযোগের জন্য ব্যবহৃত হবে।
CouchDB ডেটা সংরক্ষণের জন্য Persistent Volume (PV) এবং Persistent Volume Claim (PVC) ব্যবহার করা গুরুত্বপূর্ণ। Kubernetes এ PVC এর মাধ্যমে ডেটা স্থায়ীভাবে সংরক্ষণ করা হয়।
couchdb-pvc.yaml ফাইলটি তৈরি করুন:
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: couchdb-pvc
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 5Gi
এটি ৫Gi স্টোরেজের জন্য একটি Persistent Volume Claim তৈরি করবে।
Kubernetes এ CouchDB ক্লাস্টার তৈরি করার জন্য, একাধিক CouchDB পডের জন্য StatefulSet ব্যবহার করা হয়, কারণ CouchDB ডিস্ট্রিবিউটেড ডাটাবেস এবং প্রতিটি পডের জন্য একটি স্থায়ী আইডেন্টিটি প্রয়োজন।
couchdb-statefulset.yaml ফাইলটি তৈরি করুন:
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: couchdb-cluster
spec:
serviceName: "couchdb-cluster"
replicas: 3
selector:
matchLabels:
app: couchdb
template:
metadata:
labels:
app: couchdb
spec:
containers:
- name: couchdb
image: couchdb:latest
ports:
- containerPort: 5984
volumeMounts:
- name: couchdb-storage
mountPath: /opt/couchdb/data
volumeClaimTemplates:
- metadata:
name: couchdb-storage
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 5Gi
এই YAML ফাইলটি CouchDB ক্লাস্টার তৈরির জন্য StatefulSet ব্যবহার করবে, যা তিনটি পড তৈরি করবে এবং তাদের জন্য পৃথক Persistent Volume প্রস্তাব করবে।
CouchDB ক্লাস্টারে ডেটা রেপ্লিকেশন এবং নোড যোগ করার জন্য cluster setup কনফিগারেশন দরকার। এটি করার জন্য, আপনি CouchDB HTTP API ব্যবহার করতে পারেন।
আপনি প্রথমে CouchDB এর _cluster_setup API ব্যবহার করে ক্লাস্টারের প্রাথমিক কনফিগারেশন করতে পারেন। এতে আপনাকে ক্লাস্টারে নোড যুক্ত করতে হবে এবং বিভিন্ন CouchDB পডের মধ্যে রেপ্লিকেশন কনফিগার করতে হবে।
curl -X POST http://admin:password@couchdb-cluster-0.couchdb-cluster:5984/_cluster_setup -d '{"action":"enable_cluster", "username":"admin", "password":"password", "node_count":3}'
এখানে:
প্রথম নোড সেটআপ করার পরে, আপনি অন্য নোডগুলোকে ক্লাস্টারে যোগ করতে পারেন:
curl -X POST http://admin:password@couchdb-cluster-0.couchdb-cluster:5984/_cluster_setup -d '{"action":"add_node", "host":"couchdb-cluster-1.couchdb-cluster", "username":"admin", "password":"password"}'
এভাবে প্রতিটি CouchDB পডকে ক্লাস্টারে যোগ করা হয়।
Kubernetes এ CouchDB ক্লাস্টার মনিটর করতে kubectl ব্যবহার করে পডের স্ট্যাটাস চেক করতে পারেন:
kubectl get pods
kubectl describe pod couchdb-cluster-0
Kubernetes ক্লাস্টারে CouchDB পডের সংখ্যা পরিবর্তন করতে হলে:
kubectl scale statefulset couchdb-cluster --replicas=5
এটি ক্লাস্টারে আরও দুটি CouchDB পড যোগ করবে।
CouchDB পডের লগ দেখতে:
kubectl logs couchdb-cluster-0
resources:
requests:
memory: "2Gi"
cpu: "1"
limits:
memory: "4Gi"
cpu: "2"
CouchDB এর সঙ্গে Kubernetes ইন্টিগ্রেশন CouchDB ক্লাস্টার এবং ডিস্ট্রিবিউটেড ডাটাবেস ব্যবস্থাপনাকে আরও সহজ এবং স্কেলেবল করে তোলে। Kubernetes এর সাহায্যে আপনি CouchDB এর রেপ্লিকেশন, ক্লাস্টারিং, স্কেলিং, এবং পারফরম্যান্স ম্যানেজমেন্ট সহজভাবে পরিচালনা করতে পারেন। Kubernetes এর মাধ্যমে CouchDB-কে উচ্চ উপলব্ধতা এবং ডিস্ট্রিবিউটেড আর্কিটেকচারে রূপান্তর করা সম্ভব।
common.read_more